## Microprocessor Systems

Dr. Gökhan İnce

### Addressing Methods



Op-code Operand

1 or 2 bytes 0 to 3 bytes

- Addressing identifies, where to find the operand in the memory or among the registers
- During instruction decoding, the addressing mode is detected and the effective address is obtained
- There are six main addressing methods. Additional methods are derivatives
- Higher quantity and complexity of addressing modes of a CPU designates its flexibility to execute high-level programming languages

# Op.

### **Operand Sources**



- memory location
- registers
- data

### Addressing Codes

- Major Addressing Methods
  - Immediate Addressing
  - Implied Addressing (Register Addressing)
  - Direct Addressing
  - Indirect Addressing
  - Indexed Addressing
  - Relative Addressing
- Advanced Addressing Methods
  - Memory Immediate Write
  - Incremented Index Addressing
  - Decremented Index Addressing
  - Register Relative Index Addressing



### **Immediate Addressing**

- •The operand is contained in the instruction (LDA+X)
- Instruction does not specify an address location
  - Fast instructions
- Example:

LDAB, \$41 LDS, \$1000





- The instruction contains the register indicator
- No addressing to the memory
- Used for register operations
- Short instruction length (ex. 1 Byte)
- Fast instructions
- Examples:

TAB

TAB \$1000 \$1001

# Direct Addressing

- Instruction contains the address of the operand
- Effective address of the operand is in the instruction

| LDAA    |         |            |             |
|---------|---------|------------|-------------|
| \$12    |         | LDAA       | \$1000      |
| \$50    |         | \$12       | \$1001      |
|         |         | \$50       | \$1002      |
|         |         |            |             |
|         |         |            |             |
| LDAA, < | \$1250> |            |             |
|         |         | \$95       | \$1250      |
|         |         | 1 +        |             |
|         |         | \$1250     | MAR         |
|         |         | ② ↓        |             |
|         |         | \$95       | MDR         |
|         |         | <u>(3)</u> | <del></del> |

**ACCA** 

### **Indirect Addressing**

- Instruction contains the address of the operand's address
- Effective address is at the address location specified in the instruction
- Slow instructions
- Used for queues, lists, pointer type data structures
- Examples: LDAA, ((\$2500)) LDAA, <CD>





### Direct – Indirect Addressing







### **Indexed Addressing**

- Index Register (IX) contains the first element of the data set.
- The operand's address = IX + [Index number (1-Byte)]





### Relative Addressing

- The operand's address is relative to the
   PC = PC +/- [Step size (7 bit)]
- Used for branching instructions





# Addressing Methods

| a | b | С  | d   | е | f | g | h | k | n | 0   | p   | S  | u | ٧ | У | Data/address | Data/address | address |
|---|---|----|-----|---|---|---|---|---|---|-----|-----|----|---|---|---|--------------|--------------|---------|
|   | 1 | .0 | cta |   |   |   |   |   |   | 2.0 | Oct | al |   |   |   | 3.Octal      | 4.Octal      | 5.Octal |

| Addressing Method | Effective Address Formula                                |
|-------------------|----------------------------------------------------------|
| Immediate         | Operand is in Instruction                                |
| Register          | Operand is in Register                                   |
| Direct Memory     | E.A. = <address in="" instruction=""></address>          |
| Indirect          | E.A. = contents <address in="" instruction=""></address> |
| Indexed           | E.A. = IX+Step                                           |



\$1000

\$1001

\$1002

\$1003

\$1004

- Memory **Immediate Write** 
  - Data written directly to a memory location
  - Accumulator, IX, SP, C, D contents do not change

STRM \$37, \$1250





- Incremented Index Addressing
  - Effective address computed as IX + Index
  - Then IX is incremented by the range R [1-Byte (\$00 to \$FF)] provided at the instruction





- Decremented Index Addressing
  - First the IX is decremented by R [1-Byte number (Range \$00-\$FF)]
  - Then, Address of operand = IX + Index





- Register Relative Index Addressing
  - Effective address computed as the sum of General Purpose (GP) Registers [CD], Index Register [IX], and the Index provided in the instruction
  - Size of GP and IX registers should be the same





# Instruction Set Architecture (ISA) Classification

- Based on operand location
- Type and size of operands
- Memory addressing
- Addressing modes
- Operations in the instruction set
- Instruction set encoding

## **Instruction Types**

- Data Transfer Instructions
  - Operations that move data from one place to another
  - These instructions don't actually modify the data, they just copy it to the destination
- Data Operation Instructions
  - Unlike the data transfer instructions, the data operation instructions do modify the values of data
  - They typically perform some operation using one or two data values (operands) and store the result
- Program Control Instructions
  - Jump or branch instructions are used to go to another part of the program; the jumps can be absolute (always taken) or conditional (taken only if some condition is met)
  - Specific instructions that can generate interrupts (software interrupts)



### **Instruction Types**

- Arithmetic
  - Add, Subtract, Multiply, Divide
- Logical
  - Shift, Rotate
- Data Movement
  - Load, Store
- Flow Control
  - Unconditional Branch
  - Conditional Branch

#### Instruction Set Categories for Educational CPU

| Data<br>Transfer<br>Instructions | Arithmetic-Logic-Shift Instructions                  |                                            | Program Control Instructions             | Input –<br>Output                          |                       |  |
|----------------------------------|------------------------------------------------------|--------------------------------------------|------------------------------------------|--------------------------------------------|-----------------------|--|
| Transfer (MOV)<br>(AKT)          | Add (ADD) (TOP)                                      | And (AND) (VE)                             | Compare (CMP)<br>(KAR)                   | Branch if Lower (BLO) (DEU)                | Load from I/O address |  |
| Load (LDA)<br>(YÜK)              | Add with carry (ADDC) (TOPE)                         | Or (OR) (VEYA)                             | Test (TST) (SIN)                         | Branch if Overflow (BV) (DTV)              | (LDA)<br>(YÜK)        |  |
| Store (STA)<br>(YAZ)             | Subtract (SUB)<br>(ÇIK)                              | Xor (XOR) (YADA)                           | Unconditional Jump<br>(JMP) (BAĞ)        | Branch if Carry (BC) (DEV)                 |                       |  |
| Exchange (XCH) (XCH)             | Subtract w. carry Complement (CO (SUBC) (ÇIKE) (TÜM) |                                            | Unconditional<br>Branch (BR) (DAL)       | Branch if Half Carry (BHC) (DYV)           | Store to I/O address  |  |
| Swap (SWA)<br>(DĞŞ)              | Multiply (MUL)<br>(ÇAR)                              | Logical Shift Left<br>(SHL) (SOL)          | Conditional Jump<br>(JMPC) (BAĞK)        | Branch if Not Overflow (BNV) (DTY)         | (STA)<br>(YAZ)        |  |
| Push (PUSH)<br>(YIĞ)             | Divide (DIV) (BÖL)                                   | Logical Shift Right (SHR) (SAĞ)            | No operation (NOP) (GEÇ)                 | Branch if Not Carry (BNC) (DEY)            |                       |  |
| Pop (POP)<br>(ÇEK)               | Increment (INC)<br>(ART)                             | Arithmetic Shift<br>Right (SHRA)<br>(SAĞİ) | Branch if Equal (BEQ) (DEE)              | Branch if No Half Carry (BNHC) (DYY)       |                       |  |
|                                  | Decrement (DEC) (AZT)                                | Circular Shift Left (SHLC) (SOLD)          | Branch if Not Equal (BNEQ) (DED)         | Decrement, branch if not zero (ADED) ()    |                       |  |
|                                  | Negative (NEG)<br>(EKS)                              | Circular Shift Right (SHRC) (SAĞD)         | Branch if Greater (BGT) (DEB)            | Branch to Subroutine address (ALTD) ()     |                       |  |
|                                  | Convert bin to BCD (DAA) (ONA)                       | Clear (CLR) (SiL)                          | Branch if Greater or Equal (BGE) (DBE)   | Branch to Subroutine step (ALT) ()         |                       |  |
|                                  |                                                      | Set (SET) (KUR)                            | Branch if Less (BLT) (DEK)               | Conditional Branch to Subroutine (ALTK) () |                       |  |
|                                  |                                                      |                                            | Branch if Higher<br>(BHI) (DEİ)          | Return from Subroutine (RTS) (DÖN)         |                       |  |
|                                  |                                                      |                                            | Branch if Higher or<br>Equal (BHS) (DİE) | Return from Interrupt (RTI) (DÖNK)         |                       |  |

 Data Transfer: moves the content of one register into another.

MOV R<sub>i</sub>, R<sub>j</sub>

$$R_i \leftarrow R_j$$

MOV A, B

MOV A, C

MOV B, CCR

MOV IX, SP

 Load: The load instruction copies the content of a memory location or places an immediate value into an accumulator or a register. Memory contents are not changed.

$$R_i \leftarrow \langle ADDRESS \rangle$$



 Store: Store instructions copy the content of a CPU register into a memory location. The contents of the accumulator or CPU register are not changed.

STA 
$$R_i$$
,    $\leftarrow$   $R_i$ 

STA A, \$1000 \$1000  $\leftarrow$  ACC A

STA C, \$E000 \$E000  $\leftarrow$  C

STA IX, \$C000 \$C000 + \$C001  $\leftarrow$  IX



 Exchange: Exchange instructions exchange the contents of pairs of registers or accumulators.

XCH 
$$R_i$$
,  $R_j$   $R_i \leftarrow R_j$ 

XCH A, B 
$$\rightarrow$$
 ACC A  $\rightarrow$  ACC B

XCH C, D 
$$C \longleftrightarrow D$$

XCH IX, SP 
$$IX \longleftrightarrow SP$$

Swap: The bits are divided into groups of four. Swap insructions are used to swap the content of the first group with the second one.

SWA 
$$R_i$$
,  $R_i[D_3, D_2, D_1, D_0 - D_7, D_6, D_5, D_4]$ 

SWA A

Push: The contents of the accumulators are pushed onto the stack

PUSH A push the contents of ACCA onto stack

PUSH B push the contents of ACCB onto stack

 Pop: Pop instructions are used to read data into the specified accumulator from the stack

POP A data on top of the stack is retrieved to ACCA

POP B data on top of the stack is retrieved to ACCB



#### **Arithmetic Instructions**

 Add: Add instructions are used to add the content specified, either in an accumulator or in a register or in memory location, into the accumulator. The result is stored in the accumulator.

 Add with Carry: Add operation is performed by including the carry flag.

ADDC A, B  $ACCA \longleftarrow ACCA+ACCB+C \\ ADDC A, R_i \qquad ACCA \longleftarrow ACCA+R_i+C \\ ADDC A, DATA \qquad ACCA \longleftarrow ACCA+DATA+C \\ ADDC A, <ADDRESS> \qquad ACCA \longleftarrow ACCA+<ADDRESS>+C$ 



#### Add Instruction

ADD A, B

 $ACC A \leftarrow ACC A + ACC B$ 

ADDC A, B

 $ACC A \leftarrow ACC A + ACC B + C$ 

ADD A, \$25

ACC A ← ACC A +\$25

ADD A, <\$1000>

ACC A  $\leftarrow$  ACC A + <\$1000>

ADDC A, <IX+10>

 $ACC A \leftarrow ACC A + \langle IX+10 \rangle + C$ 

#### **Add Instruction**

This program reads two numbers (N1,N2) from memory, adds them and stores the result into memory.

$$N1 + N2 \rightarrow S$$
  
 $N1 \rightarrow $C200$   
 $N2 \rightarrow $C201$   
 $S \rightarrow $C202$ 

 The program starts at memory location \$C000.



#### **Add Instruction**

Example: Add two numbers X=\$40A0 and Y=\$1BC1

```
<10> <11> X <10>:0100 0000 <12> <13> Y <11>:1010 0000 <12>:0001 1011 <14> <15> RESULT <13>:1100 0001
```

#### **Subtract Instruction**

 Subtract: Substract instructions are used to subtract the specified contents, in an accumulator or in a register or in the memory location, from the contents of the accumulator. The result is stored in the accumulator.

| SUB A, B | ACCA ← | — ACCA-ACCB |
|----------|--------|-------------|
|----------|--------|-------------|

SUB A, 
$$R_i$$
 ACCA  $\leftarrow$  ACCA- $R_i$ 

#### Subtract with Borrow

SBC A, 
$$R_i$$
 ACCA  $\leftarrow$  ACCA- $R_i$ -C



#### **Arithmetic Instructions**

- Multiplication:
  - The multiplicand is in ACCA.
  - The multiplier is in ACCB or in an 8 bit register or in a memory location or an immediate data.
  - The result is stored in ACCA and ACCB.
  - The multiplicand and multiplier are unsigned.



#### **Arithmetic Instructions**

#### Division:

- The dividend is in ACCA and ACCB pair.
- The divisor is an 8 bit register or a memory location or an immediate data.
- The quotient is in ACCA and ACCB pair and the remainder is in C.
- The dividend and the divisor are unsigned numbers.
- If the divisor is 0, the overflow flag in CCR is set.

```
DIV AB, R_i ACCA + ACCB \leftarrow <ACCA + ACCB> / R_i DIV AB, DATA ACCA + ACCB \leftarrow <ACCA + ACCB> / DATA DIV AB, <ADDRESS> ACCA + ACCB \leftarrow <ACCA + ACCB>/<ADDRESS>
```

# Example #1

The 16 bit number in memory locations \$1000 and \$1001 will be divided to the number in memory location \$1002. The result and the remainder will be stored in memory locations \$1005-\$1006 and \$1007 respectively.

```
LDA IX, $1000

LDA A, <IX+0> + $01

LDA B, <IX+0> + $01

DIV AB, <IX+0>

STA AB, $1005

STA C, $1007
```

### Example #2

The operands in memory locations \$1000 and \$1001 will be multiplied, then divided to the operand in memory location \$1002. The result will be stored at memory locations \$1005-\$1006, remainder will be stored at memory location \$1007

| START | LDA IX, \$1000               | <b>IX</b> ← \$1000 |
|-------|------------------------------|--------------------|
|       | LDA A, <ix+0> + \$01</ix+0>  | <b>IX</b> ← \$1001 |
|       | MUL A, <ix+0> + \$01</ix+0>  | <b>IX</b> ← \$1002 |
|       | DIV AB, <ix+0></ix+0>        | IX ← \$1002        |
|       | LDA IX, \$1005               | <b>IX</b> ← \$1005 |
|       | STA AB, <ix+0> + \$02</ix+0> | IX ← \$1007        |
|       |                              | 34                 |